Automated method for generating the cyclic redundancy check, or CRC, particularly for the transmission of multi-protocol packets in packet-switching networks

ABSTRACT

The invention concerns an automated method to generate the Cyclic Redundancy Check, or CRC, of data packets, minimizing computing time, particularly for the transmission of recursively embedded packets in packet-switching networks, particularly able to carry out the calculation even in case the packet length (as number of bits) is not a multiple integer of processed word width. The invention also concerns the CRC and checksum checking and computing machines carrying out the described calculation.

[0001] This invention concerns an automated method to generate the Cyclic Redundancy Check, or CRC, particularly for the transmission of multi-protocol packets in packet-switching networks, and to minimize CRC computing time for packets including a stack of protocols, this method always being simple, reliable and efficient.

[0002] This invention also concerns the necessary tools to implement the method and all the equipments working in accordance to the method. This method can be implemented on network nodes via dedicated processing machines.

[0003] It is well known that the telecommunications industry is currently dominated by the internet, whose protocol (IP) requires messages to be suitably processed and transmitted via a stack of different protocols structured into a certain number of independent levels for data transmission.

[0004] The message to be transmitted is inserted in a packet or datagram composed of three different portions: 1) the payload, containing the message itself; 2) the header and 3) the trailer. The header and/or the trailer contain some service information, such as the type of data/packet and the IP address of the sender and receiver, and the so-called Frame Check Sequence (FCS) in order to check for proper transmission or to safeguard some specific fields of the packet.

[0005] Owing to the required number of protocols, a packet may constitute the payload for a lower level packet in the Open System Interconnect (OSI) stack, making up the cited protocol stack.

[0006] As already mentioned, transmission error detection techniques are provided in order to allow the receiver of a message, transmitted via a noisy channel (which introduces errors), to assess whether the message received has been corrupted during transmission. For these purposes, the transmitter calculates a value, called FCS, that is a function of the message and attaches it to the message being sent. The FCSs generally belong to two distinct classes characterized by different properties and computing methods respectively called checksum and Cyclic Redundancy Check (CRC) algorithms. The FCSs calculated via CRC algorithms leave the data to be transmitted intact and add a particular control word, called CRC, at the end. Therefore, for calculating the CRC, the part of the packet whose proper transmission must be checked is sent to a CRC computer that will generate the result as soon as it receives the final data. This activity is usually carried out in serial mode, so that the flow of bits enters the linear feedback shift register (LFSR) and, after the last bit has entered, an outgoing flow with the resulting CRC will be produced. In particular, the CRC depends on the characteristic generator polynomial of the LFSR.

[0007] Given a sequence of k (≧1) input bits or scalars u[t₀], u[t₀+1], u[t₀+2], . . . , u[t₀+k], representing the binary data for the LFSR input, and an n degree generator polynomial, the CRC calculation on the input data depends on the initial state x[t₀] of the LFSR and on the input sequence:

CRC=f(x[t ₀ ], u[t ₀ ], u[t ₀+1], . . . , u[t ₀ +k])

[0008] In fact, supposing x[t₀] is known, given a positive integer w less than or equal to k, we obtain: ${\underset{\_}{x}\left\lbrack {t_{0} + 1} \right\rbrack} = {{A \cdot {\underset{\_}{x}\left\lbrack t_{0} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack t_{0} \right\rbrack}}}$ ${\underset{\_}{x}\left\lbrack {t_{0} + 2} \right\rbrack} = {{A \cdot {\underset{\_}{x}\left\lbrack {t_{0} + 1} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + 1} \right\rbrack}}}$ ⋮ ${\underset{\_}{x}\left\lbrack {t_{0} + w} \right\rbrack} = {{A \cdot {\underset{\_}{x}\left\lbrack {t_{0} + w - 1} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + w - 1} \right\rbrack}}}$

[0009] where:

[0010] x[t_(i)] is the state vector (n,1) of the linear system described by the above equations referred to instant t_(i);

[0011] A is the state matrix (n,n) of the system, whose elements depend on the coefficients of the generator polynomial;

[0012] b is a vector (n,1) of the type b=[1 0 0 . . . 0]^(T).

[0013] Substituting the (i−1)th equation in the i-th equation iteratively, we obtain the following compact form:

x[t ₀+1]=A·x[t ₀ ]+b·u[t ₀] $\begin{matrix} {{\underset{\_}{x}\left\lbrack {t_{0} + 2} \right\rbrack} = {{A \cdot {\underset{\_}{x}\left\lbrack {t_{0} + 1} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + 1} \right\rbrack}}}} \\ {\quad {= {{A \cdot \left( {{A \cdot {\underset{\_}{x}\left\lbrack t_{0} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack t_{0} \right\rbrack}}} \right)} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + 1} \right\rbrack}}}}} \\ {\quad {= {{A^{2} \cdot {\underset{\_}{x}\left\lbrack t_{0} \right\rbrack}} + {A^{1} \cdot \underset{\_}{b} \cdot {u\left\lbrack t_{0} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + 1} \right\rbrack}}}}} \\ \vdots \\ {{\underset{\_}{x}\left\lbrack {t_{0} + w} \right\rbrack} = {{A \cdot {\underset{\_}{x}\left\lbrack {t_{0} + w - 1} \right\rbrack}} + {\underset{\_}{b} \cdot {u\left\lbrack {t_{0} + w - 1} \right\rbrack}}}} \\ {\quad {= {{A^{w} \cdot {\underset{\_}{x}\left\lbrack t_{0} \right\rbrack}} + {A^{w - 1} \cdot \underset{\_}{b} \cdot {u\left\lbrack t_{0} \right\rbrack}} + {A^{w - 2} \cdot \underset{\_}{b} \cdot {u\left\lbrack {t_{0} + 1} \right\rbrack}} + \ldots +}}} \\ {\quad {A^{0} \cdot \underset{\_}{b} \cdot {u\left\lbrack {t_{0} + w - 1} \right\rbrack}}} \end{matrix}$

[0014] where A⁰=I is the identity matrix and A^(i) is the i-th power of A.

[0015] This compact form underlies a “parallel” computation method of CRC that is very useful in several applications. The following description is made on the assumption that the CRC computation is being carried out w bit at a time, so that the CRC calculation on the whole input sequence of k samples will be carried out in k/w steps, where k is a multiple of w. This simplifying hypothesis is not determining for illustrating the procedure and will in any case be removed later on.

[0016] As regards the computation method, in real applications, the input sequence may be processed in several steps, each of them operating on a subsequence of the overall sequence, as shown below.

[0017] Now, defining a binary vector u_(w)[t] collecting the values of u from instant t to instant t+w−1 of the generic subsequence of length w (t coincides with t₀ only for the first subsequence) ${{\underset{\_}{u}}_{w}\lbrack t\rbrack} = \begin{bmatrix} {u\lbrack t\rbrack} \\ {u\left\lbrack {t + 1} \right\rbrack} \\ \vdots \\ {u\left\lbrack {t + w - 1} \right\rbrack} \end{bmatrix}$

[0018] the expression of the state vector becomes

x[t+w]=A ^(w) ·x[t]+B _(w) ·u _(w) [t]

[0019] where B_(w) is a matrix of dimensions (n,w) defined as

B _(w) =[A ^(w−1)

·b

A ^(w−2)

·b

. . .

A ⁰ ·b]

[0020] where each column of B_(w) is the first column of the matrices A^(i) (for i=0 . . . w−1). Thus, by representing in the compact form each subsequence of length w, we obtain the following representation ${\underset{\_}{x}\left\lbrack {t_{0} + {1 \cdot w}} \right\rbrack} = {{A^{w} \cdot {\underset{\_}{x}\left\lbrack t_{0} \right\rbrack}} + {B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack t_{0} \right\rbrack}}}$ ${\underset{\_}{x}\left\lbrack {t_{0} + {2 \cdot w}} \right\rbrack} = {{A^{w} \cdot {\underset{\_}{x}\left\lbrack {t_{0} + w} \right\rbrack}} + {B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {t_{0} + w} \right\rbrack}}}$ ⋮ ${\underset{\_}{x}\left\lbrack {t_{0} + {\left( {i + 1} \right) \cdot w}} \right\rbrack} = {{A^{w} \cdot {\underset{\_}{x}\left\lbrack {t_{0} + {i \cdot w}} \right\rbrack}} + {B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {t_{0} + {i \cdot w}} \right\rbrack}}}$ ⋮ ${\underset{\_}{x}\left\lbrack {t_{0} + {\left( {k/w} \right) \cdot w}} \right\rbrack} = {{A^{w} \cdot {\underset{\_}{x}\left\lbrack {t_{0} + {\left( {\left( {k/w} \right) - 1} \right) \cdot w}} \right\rbrack}} + \quad {B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {t_{0} + {\left( {\left( {k/w} \right) - 1} \right) \cdot w}} \right\rbrack}}}$

[0021] The last equation represents the state vector after k/w steps (as a function of the previous step) defined as the CRC of the input sequence according to the associated generator polynomial.

[0022] The value of CRC may be rewritten as a function only of the initial state and of the input sequence by iterative substitution of state i by its expression as a function of state i−1. By carrying out the described substitution and putting p=k/w and t₀=0, without losing the generality, we obtain $\begin{matrix} {{\underset{\_}{x}\left\lbrack {p \cdot w} \right\rbrack} = {{A^{p \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{\text{?}}{{A^{{({p - 1 - i})}w} \cdot B_{w} \cdot {{{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}.\text{?}}}\text{indicates text missing or illegible when filed}}}}} & \lbrack 0\rbrack \end{matrix}$

[0023] Thus, the CRC may be obtained by iterating k/w=p times the following matrix form:

x[t ₀+(i+1)·w]=A ^(w) ·x[t ₀ +i·w]+B _(w) ·u _(w) [t ₀ +i·w]  [1]

CRC=x[t ₀+(k/w)·w]=x[p·w]  [2]

[0024] where:

[0025] x is the LFSR state vector, of dimension (n,1), already introduced;

[0026] A^(w) is the already defined matrix (n, n);

[0027] B_(w) is the already defined matrix (n, w).

[0028] The value of the elements of matrices A^(w) and B_(w) depends on the generator polynomial.

[0029] The calculation may thus be performed in k/w clock cycles with a period w times greater than the one of the serial computer that is able to process the same amount of data at the same time.

[0030] If k is not a multiple of w, then we proceed—as in the case already described—by first iterating matrix form [1] m times to obtain state x[t₀+m·w], and then reusing it as the initial state in the following formula that is similar to [1] but which operates on k−m·w bit parallel data

x[t ₀ +k]=A _(k−m·w) ·x[t ₀ +m·w]+B _(k−m‘w) ·u _(k−m·w) [t ₀ +m·w].   [1A]

[0031] where m is the integer quotient of k/w, and k−m·w is the remainder of the division of k by w.

[0032] In the case of a protocol stack, the CRC is calculated for each nested protocol, with the result that the CRC of lower level protocols, which include higher level protocols, depends on the CRCs of the nested protocols.

[0033] Since the CRCs (or checksums) of the internal protocols may be part of the sequence of data processed by the protocol containing them, the CRC calculation of the external protocol must be suspended until the aforesaid values become available. Usually, first one calculates the higher level CRC, then the one immediately below and so on up to the most external one.

[0034] These solutions call for a considerable amount of time because a complete processing is necessary for each level of the stack, and this means long waiting time in order to complete the CRC calculation of the higher level protocols before going on to calculate the CRC of the lower level protocol. In particular, the total time required by the CRC calculation is roughly proportional to the number of levels of the protocol stack.

[0035] Hence, in many cases, the lowest level protocol CRC calculation requires a significantly longer time than the actual duration of the packet.

[0036] As an example, see FIG. 1, which shows a stack of two protocols. Supposing that CRC (or checksum) C2 of the internal protocol is calculated on the data contained in header H2, in payload P2 and in trailer T2 of the protocol itself; CRC C1 of the external protocol covers H1, P1 and T1, where payload P1 is composed of all the higher protocol data. Note that payload P1 contains C2, that is the FCS of another protocol; moreover, C2 must be calculated on a significant part (P2+T2) of the data following it and thus, in order to complete the calculation, in any case it will be necessary to wait until all the packet (P2+T2) is available.

[0037] The network processors available on the market calculate C1 and C2 as shown in FIG. 2, which illustrates the state of activity of the computing machines in the time domain to obtain the CRC C1 as a final result. The purpose of FIG. 2 is to highlight the total calculation time in the aforesaid “traditional” mode.

[0038] The machine that calculates C2 starts operating at H2 and finishes at the end of T2; at this point, the value of C2 is available.

[0039] The machine that calculates C1 starts processing at H1 but must stop before C2 and can only resume when this field is available, because the result of the calculation of a CRC on a certain data sequence, unlike checksums, depends on the order in which data arrive.

[0040] In FIG. 2, the CRC C1 and CRC C2 are expressed according to the definition of function f introduced previously: CRC=f(x[t₀], u[t₀], u[t₀+1], . . . , u[t₀+k]). In FIG. 2, the arguments of f for calculating C2 are in the following order: the initial state X0₂ of the computing machine, the packet header H2, the packet payload P2 and the packet trailer T2. The same formula applies for calculating C1.

[0041] As FIG. 2 shows, the time that goes by before the external CRC C1 is available is the sum of the duration of the whole frame (H1+C1+P1+T1) and of the duration of the internal packet data following the internal CRC (or checksum) C2 (P2+T2).

[0042] This invention thus aims to generate the CRCs of embedded packets in packet-switching networks, minimizing the CRC calculation time for packets including a stack of protocols.

[0043] The specific item of this invention is an automated method for generating the Cyclical Redundancy Control, or CRC, of a data packet, particularly for the transmission of embedded packets in packet-switching networks where a CRC is calculated via a LFSR, which performs the calculation of a n−1 degree polynomial, according to the following relation

x[t ₀+1]=A·x[t ₀ ]+b·u[t ₀]

[0044] where x is the state vector of the LFSR of dimension (n,1), and u is the incoming data vector, hence

x[t ₀+(i+1)·w]=A ^(w) ·x[t ₀ +i·w]+B _(w) ·u _(w) [t ₀ +i·w]  [1]

[0045] where A^(w) is a matrix (n,n) and B_(w) is a matrix (n,w), the CRC being calculated by means of the following relation

CRC=x[t ₀+(k/w)·w]=x[p·w]  [2]

[0046] at least one external CRC (C1 of FIG. 1) covers incoming binary data of length k (where k=p w and p is the number of w bit data words) u_(w)[t₀], u_(w)[t₀+1], u_(w)[t₀+2], . . . , u_(w)[t₀+h], . . . , u_(w)[t₀+h+c−1], . . . , u_(w)[t₀+p−1], of which a subsequence u_(w)[t₀+h], . . . , u_(w)[t₀+h+c−1] (C2 of FIG. 1) is unknown until instant (to+k-1). According to this method the external CRC (C1) is calculated by means of the following steps:

[0047] calculation of a preliminary value V, equal to

V=f(x[t ₀ ], u _(w) [t ₀ ], u _(w) [t ₀+1], . . . , u _(w) [t ₀ +h−1], 0[t ₀ +h], . . . , 0[t ₀ +h+c−1],

u _(w) [t ₀ +h+c], . . . , u _(w) [t ₀ +p−1])   [1st term of [9]]

[0048] calculation of a projection contribution PRJ, equal to

PRJ(l, u _(w) [t ₀ +h], . . . , u _(w) [t ₀ +h+c−1])   [2nd term of [9]]

[0049] sum of the preliminary value V and the projection contribution PRJ.

[0050] Preferably, if k is not a multiple of w, firstly the matrix form [1] is iterated m times to get the state x[t₀+m·w], and then it is used as the initial state in the following formula operating on k−m·w bit parallel data:

x[t ₀ +k]=A ^(k−w·m) ·x[t ₀ +m·w]+B _(k−m·w) ·u _(k−m·w) [t ₀ +m·w]  [1A]

[0051] where m is the integer part of k/w, and k−m·w is the remainder of the division of k by w.

[0052] Another specific item of this invention is a machine for checking and calculating the CRCs and checksums, including:

[0053] A frame processor (3, 4, 5, 6) for each protocol of a stack including at least two protocols; at least one frame processor is due to calculate a CRC.

[0054] At least one predictor (7), for calculating the projection contribution PRJ of the method according to claims 1 and 2.

[0055] One or more Operand Registers (8) for storing the operands of the instructions that must be executed by the aforesaid processors of the machine.

[0056] A CDT memory (9) for recording the instructions that must be executed by the aforesaid processors of the machine.

[0057] A state machine FSM (19) that reads the instructions from the CDT (9), compiles them and generates control signals.

[0058] A buffer (13) for storing the packets to be processed.

[0059] A data register set (Data Regs) (14) that stores the calculated CRC or checksum values.

[0060] For each processor (3, 4, 5, 6) and at least one predictor (7):

[0061] A Barrel-Shifter register (15) enabling the processing of words contained in two consecutive locations of the buffer (13), and

[0062] A selector circuit (16) that selects data to be processed between those coming from the buffer (13) and those coming from the Data Regs (14); control signals of Barrel-Shifter registers (15) and selector circuits (16) are provided by the aforesaid FSM machine (10).

[0063] Preferably, at least one processor (3, 4) of the frame calculates a checksum; the machine includes a Rotate circuit (17) preceding the aforesaid checksum processor (3, 4); control signals of Rotate circuit (17) are also provided by the aforesaid FSM machine. (10).

[0064] This invention will now be described, for illustration purposes, but not limited to such illustration, according to its preferred forms of realization, with particular reference to Figures of the attached drawings, in which:

[0065]FIG. 1 schematically shows a protocol stack including two nested protocols;

[0066]FIG. 2 schematically shows the CRCs computation time of the stack in FIG. 1, according to the methods of the known art;

[0067]FIG. 3 schematically shows a packet divided according to the method of the invention;

[0068]FIG. 4 schematically shows the CRCs computation time of the stack in FIG. 1, according to the method of this invention;

[0069]FIG. 5 schematically shows the CRCs computation time of a protocol stack referred to a real application, including three nested protocols, according to the method of this invention;

[0070]FIG. 6 shows a preferred mode to implement the machine, according to the invention;

[0071]FIG. 7 schematically shows a first component of the machine of FIG. 6;

[0072]FIG. 8 shows a detail of the first component of FIG. 7;

[0073]FIG. 9 shows an example of the detail of FIG. 8;

[0074]FIG. 10 shows a schematization of the packet, highlighting the relative lengths and positions of its various fields, according to which the values of certain components of the machine of FIG. 6 must be programmed;

[0075]FIG. 11 shows the values of certain components of the machine of FIG. 6 as the examples of FIG. 9 and of FIG. 10 describe;

[0076]FIG. 12 shows an example of a packet processed with the machine of FIG. 6;

[0077]FIG. 13 schematically shows a second component of the machine of FIG. 6;

[0078]FIG. 14 shows an example of a part of the packet processed by the second component of FIG. 13;

[0079]FIG. 15 shows the principle used to calculate a checksum over a packet;

[0080]FIG. 16 schematically shows how a third component of the machine of FIG. 6 works;

[0081]FIG. 17 shows a section of a packet processed by the second component of FIG. 13 and the third component of FIG. 16, as another example.

[0082] The references of the description will be used to indicate the same elements as in the Figures.

[0083]FIG. 3, section 1, shows a generic section of a packet, represented as a w bit words sequence of total length p. Three subsections, respectively of lengths h, c and l, are defined in this section.

[0084] The main point of the problem solved by the invention is calculation of a CRC on the whole section of length p, assuming the subsections of length h and l are available first, and afterwards the subsection of length c. It is then basic to this invention to show how the CRC calculation may be subdivided into a calculation over the subsections h and l and a calculation over the subsection of length c.

[0085] The inventors have developed a new method for calculating the CRC that can be advantageously applied to the generation of CRCs in the transmission of stacked packets. In fact, if

h+c+l=p, and h, c, l>0

[0086] from the formula [0] we get the following equation [3]: $\begin{matrix} {{\underset{\_}{x}\left\lbrack {p \cdot w} \right\rbrack} = {\underset{\_}{x}\left\lbrack {\left( {h + c + l} \right) \cdot w} \right\rbrack}} \\ {= {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}}} \\ {= {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} +}} \\ {{{\sum\limits_{i = h}^{h + c - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} +}} \\ {{\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \end{matrix}$

[0087] where four terms are shown:

[0088] The first one, not depending on the inputs, is the contribution of the initial state to the calculation of the CRC under examination.

[0089] The second one represents the contribution of a part of length h of the data of the packet to the calculation of the CRC under examination. With reference to FIG. 1, it is H1+H2.

[0090] The third one is the contribution of the c length data section, not available at the moment of calculation, to the computation of the CRC under examination. For example, it could be the FCS field of a protocol that is nested in the one over which the CRC is being calculated. With reference to FIG. 1, it is C2.

[0091] The fourth one is the contribution of the length I data section of the packet to the calculation of the considered CRC. With reference to FIG. 1, it is P2+T2+T1 (C1 is not an input but a result for the machine performing the current calculation).

[0092] This representation is shown in section 2 of FIG. 3. By gathering the first, second and fourth term, we obtain the equation [4]: $\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} + {\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + {\left\{ {\sum\limits_{i = h}^{h + c - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} \right\} \quad {where}\text{:}}$

[0093] The first term represents the contribution of the data known at the time of calculation.

[0094] The second term represents the contribution of the data not available at the time of the CRC calculation.

[0095] Equation [4], applying summand properties, leads to the following expression [5]: ${\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} + {\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {\sum\limits_{i = h}^{h + c - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} \right\}} = {{\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} + {\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {\sum\limits_{i = 0}^{c - 1}{A^{{({h + c + l - 1 - {({i + h})}})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {\left( {i + h} \right) \cdot w} \right\rbrack}}} \right\}} = {\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} + {\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {A^{l \cdot w} \cdot {\sum\limits_{i = 0}^{c - 1}{A^{{({c - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {\left( {i + h} \right) \cdot w} \right\rbrack}}}} \right\}}}$

[0096] The following expression [6] is obtained from [5] by adding the sequence of null inputs 0_(w) between h and h+c−1: $\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}} + {\sum\limits_{i = h}^{h + c - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {\underset{\_}{0}}_{w}}} + {\sum\limits_{i = {h + c}}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {A^{l \cdot w} \cdot {\sum\limits_{i = 0}^{c - 1}{A^{{({c - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}\left\lbrack {\left( {i + h} \right) \cdot w} \right\rbrack}}}} \right\}$

[0097] Equation [5], which represents the value of the CRC, equates to [6].

[0098] Defining the sequences of inputs u_(w)* and u_(w) ^(#) as: ${{\underset{\_}{u}}_{w}^{*}\left\lbrack {i \cdot w} \right\rbrack} = \left\{ {{\begin{matrix} 0 & {h \leq i \leq {h + c - 1}} \\ {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack} & {otherwise} \end{matrix}{{\underset{\_}{u}}_{w}^{\#}\left\lbrack {i \cdot w} \right\rbrack}} = \left\{ \begin{matrix} {{\underset{\_}{u}}_{w}\left\lbrack {i \cdot w} \right\rbrack} & {h \leq i \leq {h + c - 1}} \\ 0 & {otherwise} \end{matrix} \right.} \right.$

[0099] and by introducing them in [6], we obtain the following equation: $\begin{matrix} {{\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{*}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {\sum\limits_{i = 0}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{\#}\left\lbrack {i \cdot w} \right\rbrack}}} \right\}} = {\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{*}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {A^{lw}{\sum\limits_{i = 0}^{h + c + l - i}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{\#}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\}}} & \lbrack 7\rbrack \end{matrix}$

[0100] Both equations [7] and [3] express the value of CRC, but [7] highlights that the result may be obtained as a sum of two terms, the first one is calculated by applying [3] to the particular sequence of inputs u_(w)*, that is characterized by null vectors between h and h+c−1, and the second one is calculated over the complementary sequence u_(w) ^(#), characterized by null vectors between 0 and h−1 and between h+c and h+c+l−1 with a null initial state.

[0101] As regards implementation, the calculation is performed as shown by the following expression, obtained from [6] by introducing u_(w)* in the first term: $\begin{matrix} {\left\{ {{A^{{({h + c + l})} \cdot w} \cdot {\underset{\_}{x}\lbrack 0\rbrack}} + {\sum\limits_{i = 0}^{h + c + l - 1}{A^{{({h + c + l - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{*}\left\lbrack {i \cdot w} \right\rbrack}}}} \right\} + \left\{ {A^{l \cdot w} \cdot {\sum\limits_{i = 0}^{c - 1}{A^{{({c - 1 - i})} \cdot w} \cdot B_{w} \cdot {{\underset{\_}{u}}_{w}^{\#}\left\lbrack {\left( {i + h} \right) \cdot w} \right\rbrack}}}} \right\}} & \lbrack 8\rbrack \end{matrix}$

[0102] This corresponds to summing the results of two partial CRC calculations: the first one is performed on the whole input sequence, whose input vectors between h and h+c−1 are replaced with 0_(w); the second one is calculated over the input sequence evaluated between h and h+c−1, starting from a null initial state and multiplied by the factor A^(lw). The latter operation is called projection.

[0103] This linear property of the matrix calculation may be applied in the generation of a CRC C1 of an external protocol embedding an internal protocol as shown in FIG. 4. As a general premise for the interpretation of the figure, the section H1+H2 represents the first known data of length h in the preceding treatment, while P2+T2+T1 represents the second known data of length l in the preceding treatment; C2 instead represents the unknown section of length c. The length of each section is meant to be the number of w bit parallel words, while its calculation time is the product of the number of its words and the computer clock period. Thus, for example, the length of the internal CRC field, C2, is c words (section duration is T_(c)=c·Tclock). In FIG. 4, the internal CRC C2 is placed between a first portion, H1+H2 long (C1 is ignored because it is the result to be calculated), and a second portion P2+T2+T1 long. Thus, the CRC C1 can be obtained from the following formula

CRC=f(x[t ₀ ], u _(w) [t ₀ ], u _(w) [t ₀+1], . . . , u _(w) [t ₀ +h−1], 0[t ₀ +h], . . . , 0[t ₀ +h+c−1], u _(w) [t ₀ +h+c], . . . , u ₂ [t ₀ +p−1 ])+prj(l, u _(w) [t ₀ +h], . . . , u _(w) [t ₀ +h+c−1])   [9]

[0104] where:

[0105] The function f equates to the first term of equation [8].

[0106] The function prj, called projection, equates to the second term of equation [8], expressed in FIG. 4 as PRJ_(C2)=PRJ(t_(P2)+t_(T2), C2), where t_(P2)+t_(T2) is the projection length l used in matrix A^(l·w).

[0107] The 1st term is called V and the 2nd term is called PRJ.

[0108] The projection function depends on the projection length l (=p−h−c) and on the unknown c long data u in section C2. The expression of prj, according to the second term of [8], is $\begin{matrix} {{{prj}\left( {l,{u\left\lbrack {t_{0} + h} \right\rbrack},\ldots \quad,{u\left\lbrack {t_{0} + h + c - 1} \right\rbrack}} \right)} = {A^{l \cdot w} \cdot {\sum\limits_{i = 0}^{c - 1}{A^{{({c - 1 - i})} \cdot w} \cdot B_{w} \cdot {\underset{\_}{u_{w}^{\#}}\left\lbrack {\left( {i + h} \right) \cdot w} \right\rbrack}}}}} & \lbrack 10\rbrack \end{matrix}$

[0109] In other words, the external CRC C1 results from the sum of the first term of [8], applied on the whole input sequence u[t₀], . . . , u[t₀+p−1], where the input words from instant t₀+h to instant t₀+h+c−1, corresponding to the internal CRC C2, are replaced with the c long null sequence, and the projection contribution [10] of u[t₀+h], . . . , u[t₀+h+c−1], corresponding to the internal CRC C2, where l=p−h−c is the projection length, that is the distance between instant (t₀+h+c) of the missing input sequence and instant (t₀+p−l) of the last data word involved in external CRC C1 calculation. With reference to FIG. 4, this is expressed by the term C1=C1 ₀+PRJ_(C2), where C1 ₀ =f(X0₂, H1, H2, 0, P2, T2, T1).

[0110] In this way, the generation time of the external CRC C1 is extremely reduced. In fact, with reference to FIG. 4, the calculator of CRC C1, instead of waiting for the result of the internal CRC C2 calculation, keeps on working as well as these words were null; only when C2 becomes available, its contribution to the CRC C1 generation can be obtained through the projection formula [10] and can be added to the contribution of all remaining data through the formula [9]. The time saving in the external CRC C1 computation is approximately equal to the length of the data of the most internal protocol that are covered by CRC C2 and that follow C2 itself.

[0111] As an example, but not as a limitation in any way, FIG. 5 shows a real case (unlike in FIG. 4, it's a CRC at AAL5 protocol level while there is a checksum in the nested protocol IP/UDP), suitable to apply the method of this invention and referred to an UDP/IP/AAL5 stack based frame, where:

[0112] AAL5 protocol has a CRC-32 field, for transmission control purposes, covering the whole frame, including the IP and UDP protocols;

[0113] IP protocol uses a checksum placed in its header and covering only the IP protocol header itself;

[0114] UDP protocol performs error checking through a checksum placed in its header and covering the whole datagram.

[0115] When AAL5 CRC calculator processes the IP checksum, the projection method is not particularly useful. In fact, the amount of time saved is not significant because the length of data, covered by the IP checksum and following it, is restricted to the second section IP-H2 of the header; therefore, it would be better to stop the CRC-AAL5 computing machine until the IP checksum becomes available.

[0116] In a different way, when the UDP checksum is being processed, the method of this invention can give a big advantage. In fact, the amount of time saved during the computation is the length of the UDP payload: this length may be up to 64 k octets and thus, if we consider N bytes parallel data, the computing time saving is about 64 k/N clock cycles.

[0117]FIG. 6 shows a preferred form of implementation of a machine for checking and computing CRCs and checksums according to this invention. In particular, the machine includes a frame processor for each of four protocols of the stacks taken into consideration, and namely a UDP processor 3, an IP processor 4, and Eth processor 5 and an AAL5 processor 6: the UDP and IP processors, 3 and 4, calculate their checksums, while the Eth and AAL5 processors, 5 and 6, calculate their CRCs. The machine also includes a predictor 7 that implements the projection method for calculating the CRC according to this invention.

[0118] Every single packet is characterized by fixed information, such as the CRC position in the frame, and other variable information depending on packets, such as stack type, header and payload lengths. The variable information is carried by an informative unit, called Tag, 11, associated with each packet, and is stored in dedicated registers, named Operand Regs 8. Calculation control is performed by loading a program in a memory called CDT 9 (CRC/checksum Description Table), containing encoded instructions to be executed by every single processor of the machine. In particular, the CDT 9 is a memory containing several sections, one for each processed protocol stack. Each section contains the instructions that must be executed by each CRC or checksum processor. The values of the operands of these instructions are stored in the Operand Regs 8, some of which are written by the Tag while others contain fixed information. As an illustration, if the CDT 9 indicates that a certain processor must carry out the CRC computing instruction on a portion of the data packet, the number of bytes on which to carry out the calculation is read by the FSM 10 block in one of the OperandRegs 8, whose address is written in the instruction taken from the CDT 9.

[0119] The FSM 10 block is a finite state machine that reads the instructions from the CDT 9 and “compiles” them, generating the signals for controlling the processors and the dataflow.

[0120] The data frame 12 pass through a buffer 13 which has a number of ports equal to the number of processors, such that each processor 3, 4, 5, 6, and 7 can access a different data. The word that must be processed may come from the aforesaid buffer 13 or from a Data Regs 14, storing the CRC or checksum values calculated by each processor. As an illustration, when the AAL5 calculator processes the IP checksum, then this data will be fetched from register 14 where it has been written by the IP processor.

[0121] The data coming from the buffer 13 go through a Barrel-Shifter 15, through which the system can process words, with a pre-defined width, even when a word is contained in two consecutive locations of the buffer 13. In particular, for each processor 3, 4, 5, 6, and 7, the machine contains one Barrel-Shifter 15 and one selector circuit 16 selecting data to be sent to its own processor between those coming from the buffer 13 and those coming from the Data Regs 14.

[0122] Bytes of data processed by blocks 3 and 4, computing the checksum, may be rotated; Rotate circuit 17 performs this operation, in order to give the bytes the right weight during the one's complement sum, as checksum generation requires.

[0123] In particular, as described below, the FSM 10 block generates the control signals of the Barrel-Shifters 15, of the selector circuits 16, and of the Rotate circuits 17. The machine in FIG. 6 works even though the length of the packet to be processed is not an integer multiple of the usual data width. As an illustration, but not as a limitation in any way, assuming a 32 bit data width, packet length may not be a multiple of 4 bytes. As regards the computation of a checksum, padding is carried out by adding “0” (neutral element of the sum) for the missing bits. Padding cannot be carried out during CRC calculation, however, because the result would be wrong. CRC processors 5 and 6 thus contain 4 sub-blocks, one for each data width, namely 1, 2, 3 and 4 bytes: the 4-byte data width block will work nearly always, while the others will do for reduced data width. For example, in case of 37 bytes packet length, data width will be the fullest for 9 clock cycles, while the remaining byte will feed through the block working 1 byte at a time.

[0124] With reference to FIG. 7, all the instructions for each CRC or checksum or projection processor depend on the set of possible protocol stacks. They are written in the program memory CDT 9 during component initialization.

[0125] CDT 9 is divided into sections 18, one for every protocol stack taken into consideration. The section to be used for processing a certain frame is addressed by a Stack_Id pointer 19, carried by the Tag 11 referring to that packet.

[0126] The section 18 for each single stack includes the Stack Length 20, which specifies the number of protocols composing the stack itself. The number of rows in each section is given by the value of the Stack Length 20; End of Line (EOL 24) code separates rows from each other.

[0127] With reference to FIG. 8, showing the single section 18 in detail, notice that each row is characterized by a machine identification code (Machine_ID) 21 indicating which computation block should carry out the instructions stored in the row itself. Each instruction is encoded by OP_Code 22; following fields in a row contain the addresses of the registers where operands, associated with the same instruction, are stored. The CDT does not contain the explicit values of the operands because some of them are variable from packet to packet (for example, frame length itself). As already mentioned, each row ends with an EOL 24.

[0128]FIG. 9 shows an example of compilation of a single section regarding UDP/IP/AAL5 stack. Each instruction contains the addresses of the Operand Regs 8. In particular, the Figure shows the following instructions:

[0129] CALC (Op Len, Dt Sel, [Reg Addr]), for which the related processor carries out the CRC or Checksum calculation, where Op Len is the operation length (as number of bytes), Dt Sel is the selector between the buffer 13 and (Dt Sel=0) and DataRegs 14 (Dt Sel=1), and Reg Addr is the optional address of the DataRegs 14;

[0130] SKIP (Op Len), for which the related processor skips the incoming data, where Op Len is the operation length (as number of bytes). The use of the SKIP instruction may be illustrated with reference to FIG. 4. More specifically, during the CRC C1 calculation, C1 field doesn't contribute to the calculation itself; for this reason, it is skipped via the SKIP instruction;

[0131] NULL IN (Op Len), for which the related processor carries out the calculation with a null input, where Op Len is the operation length (as number of bytes). With reference to FIG. 4, NULL IN is used when the projection method is applied. During the calculation of CRC C1, CRC C2 is replaced with zeros because it is not yet available when it should be processed; this corresponds to process the function u_(w)* already defined and characterized by a null sequence in C2 field position. NULL IN instruction causes null sequence insertion. With reference to FIG. 5, during IP-CHK checksum calculation, a NULL IN is carried out to process a null sequence instead of IP-CHK, since zero is the neutral element with respect to the checksum operation;

[0132] WAIT (Op Len), for which processing is disabled and the last calculated value is stored; Op Len is the operation length (as number of bytes). With reference to FIG. 4, the WAIT instruction is used to suspend processing while waiting for the result of the projector. With reference to FIG. 5, after having processed IP-H1, the AAL5 CRC computer starts a WAIT operation to wait for the completion of the IP-CHK checksum calculation;

[0133] ADD (Data Value), for which the related processor carries out the logical operation of XOR of its result and the Data Value data, coming from another processor (namely, the projector). With reference to FIG. 4, the ADD instruction carries out the sum of the two terms of equation [8], where the first term is the state of the CRC computer after processing the sequence u_(w)* while the second term is the result of the projection operation;

[0134] PREDICT (Prj Len, Data Value), for which the predictor 7 carries out the projection operation, where PrjLen is the projection length and Data Value is the data to be projected. With reference to FIGS. 4 and 5, the result of the PREDICT operation corresponds to the second term of equation [8].

[0135] The SKIP operation differs from the WAIT one. In fact, the SKIP operation does not process a given number of bytes. Moreover it does not cause buffering of not processed data. The WAIT operation suspends the calculation, but causes a buffering of not processed data, and enables a following CALC operation to process them later (in this case, a pointer records the position of last data before WAIT execution).

[0136]FIG. 10 is a representation of UDP/IP/AAL5 frame, as shown in the non-limiting example of FIG. 5, that supports in the description of the next Figures.

[0137]FIG. 11 shows the content of the OPERAND REGS 8 and DATA REGS 14 registers, in the same case.

[0138] The FSM 10 block includes one compiler for each processor. The compiler reads the CDT 9 row that it refers to and generates the control signals for its own processor. With reference to FIG. 12, each compiler includes the following pointers:

[0139] PKTCNT, which is an index of the bytes of the whole frame passing through the input port of the machine, including data that the compiler must ignore. This pointer is not active during the WAIT operation, but it is during SKIP.

[0140] DTPCNT, which is a counter of the bytes processed by the machine. This pointer is different from PKTCNT, because it is not active during SKIP. Nevertheless, like PKTCNT, it stops during WAIT.

[0141] BUFPNT, which is a pointer to the data of the Buffer 13 to be sent to the machine. It indicates the delay—expressed as number of clock cycles—from input to output of the Buffer 13. During the WAIT operation, this pointer indicates the byte where the operation following WAIT should start.

[0142] With reference to FIG. 6, some other pointers are:

[0143] BSHSEL, which is a selector of the Barrel-Shifter 15 for the 4-byte width data, ranges from 0 to 3 and indicates how many bytes of the previous location of the buffer contribute to the current data word.

[0144] ROTSTEP, which is the byte rotation factor of the word to be processed; it's used by the Rotate circuits 17, during checksum calculation by the processors 3 and 4, to give bytes the right weight the one's complement sum requires;

[0145] The following equations are true for the described pointers:

BSHSEL=((−PKTCNT)₄)

ROTSTEP=(DTPCNT)₄

BUFPNT=Int(PKTCNT/4)

[0146] Where the ( )_(m) operator is defined as: $(n)_{m} = \left\{ \begin{matrix} {{remainder}\quad {of}\quad {n/m}} & {{{if}\quad n} \geq 0} \\ {m - \left( {- n} \right)_{m}} & {{{if}\quad n} < 0} \end{matrix} \right.$

[0147] Int is the operator “integer part of”.

[0148]FIG. 13 shows a preferred mode to implement a barrel-shifter 15. It allows the elaboration of a 32-bit data word, even when the processed word is shared by two consecutive packet words. The selectors 26 choose each byte of the output word between the current frame word and the last one, from the input interface 25. The FSM 10 generates BSHSEL control signal. To allow the selection, a three-registers delay line 27 (D type Flip-Flop based) has been put into the circuit connecting the input interfaces 25 to the selectors 26.

[0149] As shown in FIG. 14, if data directed towards the processor start, for example, from the eleventh byte b10 of the packet, then the word exiting the Barrel Shifter must be made up of bytes b10, b11 b12, b13, so PKTCNT and BSHSEL values are:

[0150] PKTCNT=10, and

[0151] BSHSEL=2

[0152] BSHSEL thus selects 2 bytes, b10 and b11, from the old word and two bytes, b12 and b13, from the new one, and collects them together to compose the output word.

[0153] As an example of checksum calculation, FIG. 15 helps to understand why the Rotate circuits 17, shown in the next FIG. 16, have been introduced. The checksum is a 16-bit word (two bytes: C0 and C1) obtained from the one's complement of the one's complement sum of all the 16-bit words involved in checksum calculation.

[0154] Bytes C0 and C1 of the checksum are initially set to 0. At time t=0, the sum of the 16-bit words [b0, b1] and [b2, b3] increments the initial value; the result, at time t=1, is incremented by the sum of the 16-bit words [b4, b5] and [b6, b7].

[0155] Note that the checksum value depends on the position of the bytes within the word to be processed (as shown in the example of FIG. 17). That's why the Rotate circuits 17 are introduced.

[0156] As already mentioned, the Rotate circuits 17 restore the right order of bytes in calculating a checksum. FIG. 16 shows the rotation logic of the preferred mode to implement the Rotate circuits 17.

[0157] As an illustration, consider the situation shown in FIG. 17, where the checksum processor must calculate the 16-bit one's complement sum of all the 32-bit words of the packet, where the most significant bytes are b0, b4, b8, . . . , while the least significant ones are b3, b7, b1, . . . , and bytes from b0 to b6 have already been processed. If

[0158] PKTCNT=DTPCNT=7, and

[0159] BSHSEL=1 (that selects the least significant byte of the previous word and the three most significant bytes of the current one)

[0160] then, at the output of the Barrel-Shifter 15 we obtain the word b7, b8, b9, b10. Without rotation, the checksum computer would incorrectly consider b7 to be the most significant byte instead of the least significant one. If

[0161] ROTSTEP=3

[0162] the Rotate circuit 17 restores the right weight of the bytes of the word to be processed.

[0163] Generally, when the machine calculates a checksum, the bytes fetched from a register, if required, are rotated according to the following rule:

ROTSTEP=(DTPCNT)₄

[0164] This invention has been disclosed by describing the preferred forms of realization with some suggested variations, but it should be understood that modifications and changes may be made by the persons skilled in the art without departing from the scope of the invention as defined in the appended claims. 

1. An automated method for generating the Cyclic Redundancy Check, or CRC, of a data packet, particularly for the transmission of packets recursively embedded in packet-switching networks, where a CRC is calculated by means of a linear feedback shift register, or LFSR, carrying out the calculation of a n-degree polynomial according to the following formula x[t ₀+1]=A·x[t ₀ ]+b·u[t ₀] where x is the LFSR state vector of size (n,1), and u is the incoming vector, for which x[t ₀+(i+1)·w]=A ^(w) ·x[t ₀ +i·w]+B _(w) ·u _(w) [t ₀ +i·w   [1] where A^(w) is a (n,n) matrix and B_(w) is a (n,w) matrix, the CRC being calculated by means of the following formula CRC=x[t ₀+(k/w)·w]=x[p·w   [2] at least one external CRC (C1 of FIG. 1) covering incoming binary data u_(w)[t₀}, u_(w)[t₀+1], u_(w)[t₀+2], . . . , u₂[t₀+h], . . . , u_(w)[t₀+h+c−1], . . . , u_(w)[t₀+p−1], of length k (where k=p·w, p being the number of w-bit data words), in which a data sequence u_(w)[t₀+h], . . . , u_(w)[t₀+h+c−1] (C2 of FIG. 1) is unknown until the instant (t₀+k−1), the method being characterized by calculating the aforesaid external CRC (C1) via the following steps: calculation of a preliminary value V, equal to V=f(x[t ₀ ], u _(w) [t ₀ ], u _(w) [t ₀+1], . . . , u _(w) [t ₀ +h−1], 0[t ₀ +h], . . . , 0[t ₀ +h+c−1], u _(w) [t ₀ +h+c], . . . , u _(w) [t ₀ +p−1])   [1st term of [9]] calculation of a projection contribution PRJ, equal to PRJ(l, u_(w)[t₀+h], . . . , u_(w)[t₀+h+c−1])   [2nd term of [9]] sum of the preliminary value and of the projection contribution PRJ.
 2. A method according to claim 1 able to carry out the calculation in case k is not a multiple integer of w, first iterating m times the matrix form [1] to reach the state x[t₀+m·w], and then using it as the initial state in the following formula operating k−m·w bits a time: x[t ₀ +k]=A ^(k−m·w) ·x[t ₀ +m·w]+B _(k−m·w) ·u _(k−m·w) [t ₀ +m·w]  [1A] where m is the integer part of k/w, and k−m·w is the remainder of k/w.
 3. A checking and computing machine for CRCs and checksums, including: A frame processor (3, 4, 5, 6) for each protocol of multi-protocol stacks, at least one processor (3, 4, 5, 6) of the frame being a CRC calculator; At least one predictor (7) calculating the projection contribution PRJ of the method according to claim 1 One or more registers, Operand Regs (8), in order to store the operands of the instructions to be executed by the processors (3, 4, 5, 6) and by the predictor (7) A CDT (9) memory in order to store encoded instructions to be executed by the processors (3, 4, 5, 6) and by the predictor (7) A finite state machine FSM (10), fetching the instructions from the CDT (9) and compiling them to generate control signals A buffer (13) to store the packets to be processed A Data Regs (14) register where the calculated CRC or checksum are stored For each of the said processors (3, 4, 5, 6) and of the said at least one predictor (7): A Barrel-Shifter (15) register, enabling the processing of words shared by two consecutive locations of the buffer (13), and A selector circuit (16), selecting data to be processed from the buffer (13) or from the Data Regs (14), the FSM (10) machine generating the control signals of the Barrel-Shifters (15) and of the selector circuits (16).
 4. A machine according to claim 3, characterized by including at least one checksum calculation processor (3, 4), a Rotate circuit (17) feeding input data through the said at least one checksum calculation processor (3, 4), and the finite state machine FSM (10) generating the control signals of the said Rotate circuit (17).
 5. A checking and computing machine for CRCs and checksums, including: A frame processor (3, 4, 5, 6) for each protocol of multi-protocol stacks, at least one processor (3, 4, 5, 6) of the frame being a CRC calculator; At least one predictor (7) calculating the projection contribution PRJ of the method according to claim 2 One or more registers, Operand Regs (8), in order to store the operands of the instructions to be executed by the processors (3, 4, 5, 6) and by the predictor (7) A CDT (9) memory in order to store encoded instructions to be executed by the processors (3, 4, 5, 6) and by the predictor (7) A finite state machine FSM (10), fetching the instructions from the CDT (9) and compiling them to generate control signals A buffer (13) to store the packets to be processed A Data Regs (14) register where the calculated CRC or checksum are stored For each of the said processors (3, 4, 5, 6) and of the said at least one predictor (7): A Barrel-Shifter (15) register, enabling the processing of words shared by two consecutive locations of the buffer (13), and A selector circuit (16), selecting data to be processed from the buffer (13) or from the Data Regs (14), the FSM (10) machine generating the control signals of the Barrel-Shifters (15) and of the selector circuits (16).
 6. A machine according to claim 5, characterized by including at least one checksum calculation processor (3, 4), a Rotate circuit (17) feeding input data through the said at least one checksum calculation processor (3, 4), and the finite state machine FSM (10) generating the control signals of the said Rotate circuit (17). 